```
1//**********************
2//
3// startup_ccs.c - Startup code for use with TI's Code Composer Studio.
5// Copyright (c) 2012-2013 Texas Instruments Incorporated. All rights reserved.
6// Software License Agreement
7//
8// Texas Instruments (TI) is supplying this software for use solely and
9// exclusively on TI's microcontroller products. The software is owned by
10// TI and/or its suppliers, and is protected under applicable copyright
11// laws. You may not combine this software with "viral" open-source
12// software in order to form a larger program.
14// THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
15// NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
16// NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
17// A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
18// CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
19// DAMAGES, FOR ANY REASON WHATSOEVER.
21// This is part of revision 1.1 of the EK-TM4C123GXL Firmware Package.
23//*********************
25#include <stdint.h>
26#include "hw_nvic.h"
27 #include "hw_types.h"
28
29 //**************************
30//
31// Forward declaration of the default fault handlers.
34 void Reset I SR (void);
35 static void Nmi SR(void);
36 static void FaultISR(void);
37 static void IntDefaultHandler(void);
38
39 //************************
40 //
41// External declaration for the reset handler that is to be called when the
42// processor is started
45 extern void _c_int00(void);
48 //
49// Linker variable that marks the top of the stack.
51 //*************************
52extern uint32_t __STACK_TOP;
54 //**************************
56// The vector table. Note that the proper constructs must be placed on this to
```

```
57// ensure that it ends up at physical address 0x0000.0000 or at the start of
 58// the program if located at a start address other than 0.
 60//*****
 61
                                                  // Refer to TIMER1 handler in freq_time.c
 62 extern void Timer11sr(void);
                                                  // Refer to WTIMER5 handler in freq_time.c
 63 extern void WideTimer51sr(void);
 65#pragma DATA_SECTION(g_pfnVectors, ".intvecs")
 66 void (* const g_pfnVectors[]) (void) =
 67 {
       (void (*) (void)) ((uint32_t)&__STACK_TOP),
 68
 69
                                                  // The initial stack pointer
 70
       ResetISR,
                                                  // The reset handler
 71
       Nmi SR,
                                                  // The NMI handler
 72
                                                  // The hard fault handler
       FaultISR,
 73
       IntDefaul tHandler,
                                                  // The MPU fault handler
 74
                                                  // The bus fault handler
       IntDefaul tHandler,
 75
       IntDefaul tHandler,
                                                  // The usage fault handler
 76
                                                  // Reserved
       0,
 77
                                                  // Reserved
       0,
 78
       0.
                                                  // Reserved
 79
                                                  // Reserved
       0,
                                                  // SVCall handler
 80
       IntDefaul tHandler,
 81
       IntDefaul tHandler,
                                                  // Debug monitor handler
 82
                                                  // Reserved
       0,
 83
                                                  // The PendSV handler
       IntDefaul tHandler,
 84
       IntDefaul tHandler,
                                                  // The SysTick handler
                                                  // GPIO Port A
 85
       IntDefaul tHandler,
 86
       IntDefaul tHandler,
                                                  // GPIO Port B
 87
       IntDefaul tHandler,
                                                  // GPIO Port C
                                                  // GPIO Port D
 88
       IntDefaul tHandler,
 89
       IntDefaultHandler.
                                                  // GPIO Port E
 90
       IntDefaul tHandler,
                                                  // UARTO Rx and Tx (modified)
 91
       IntDefaul tHandler,
                                                  // UART1 Rx and Tx
 92
                                                  // SSIO Rx and Tx
       IntDefaul tHandler,
 93
       IntDefaul tHandler,
                                                  // I2CO Master and Slave
 94
                                                  // PWM Fault
       IntDefaul tHandler,
 95
       IntDefaul tHandler,
                                                  // PWM Generator 0
 96
                                                  // PWM Generator 1
       IntDefaul tHandler,
 97
       IntDefaul tHandler,
                                                  // PWM Generator 2
 98
       IntDefaul tHandler,
                                                  // Quadrature Encoder 0
 99
                                                  // ADC Sequence 0
       IntDefaul tHandler,
100
       IntDefaultHandler.
                                                  // ADC Sequence 1
101
       IntDefaul tHandler,
                                                  // ADC Sequence 2
102
       IntDefaul tHandler,
                                                  // ADC Sequence 3
103
       IntDefaul tHandler,
                                                  // Watchdog timer
104
       IntDefaul tHandler,
                                                  // Timer O subtimer A
105
       IntDefaul tHandler,
                                                  // Timer O subtimer B
106
                                                  // Timer 1 subtimer A
       Timer11sr,
                                                  // Timer 1 subtimer B
107
       IntDefaultHandler,
108
       IntDefaul tHandler,
                                                  // Timer 2 subtimer A
109
       IntDefaul tHandler,
                                                  // Timer 2 subtimer B
110
       IntDefaul tHandler,
                                                  // Analog Comparator 0
111
       IntDefaul tHandler.
                                                  // Analog Comparator 1
112
       IntDefaul tHandler,
                                                  // Analog Comparator 2
```

| 113        | IntDefaul tHandler, | // System Control (PLL, OSC, BO) |
|------------|---------------------|----------------------------------|
| 114        | IntDefaultHandler,  | // FLASH Control                 |
| 115        | IntDefaul tHandler, | // GPIO Port F                   |
|            | •                   |                                  |
| 116        | IntDefaul tHandler, | // GPIO Port G                   |
| 117        | IntDefaul tHandler, | // GPIO Port H                   |
| 118        | IntDefaul tHandler, | // UART2 Rx and Tx               |
| 119        | IntDefaul tHandler, | // SSI1 Rx and Tx                |
| 120        | IntDefaul tHandler, | // Timer 3 subtimer A            |
|            | •                   |                                  |
| 121        | IntDefaul tHandler, | // Timer 3 subtimer B            |
| 122        | IntDefaul tHandler, | // I2C1 Master and Slave         |
| 123        | IntDefaul tHandler, | // Quadrature Encoder 1          |
| 124        | IntDefaul tHandler, | // CANO                          |
| 125        | IntDefaul tHandler, | // CAN1                          |
|            | •                   |                                  |
| 126        | IntDefaul tHandler, | // CAN2                          |
| 127        | 0,                  | // Reserved                      |
| 128        | IntDefaul tHandler, | // Hibernate                     |
| 129        | IntDefaultHandler,  | // USB0                          |
| 130        | IntDefaul tHandler, | // PWM Generator 3               |
| 131        | IntDefaul tHandler, | // uDMA Software Transfer        |
|            | •                   |                                  |
| 132        | IntDefaul tHandler, | // uDMA Error                    |
| 133        | IntDefaul tHandler, | // ADC1 Sequence 0               |
| 134        | IntDefaul tHandler, | // ADC1 Sequence 1               |
| 135        | IntDefaul tHandler, | // ADC1 Sequence 2               |
| 136        | IntDefaul tHandler, | // ADC1 Sequence 3               |
| 137        | 0,                  | // Reserved                      |
| 138        | 0,                  | // Reserved                      |
|            | •                   |                                  |
| 139        | IntDefaul tHandler, | // GPIO Port J                   |
| 140        | IntDefaul tHandler, | // GPIO Port K                   |
| 141        | IntDefaul tHandler, | // GPIO Port L                   |
| 142        | IntDefaul tHandler, | // SSI2 Rx and Tx                |
| 143        | IntDefaul tHandler, | // SSI3 Rx and Tx                |
| 144        | IntDefaul tHandler, | // UART3 Rx and Tx               |
|            | •                   |                                  |
| 145        | IntDefaul tHandler, | // UART4 Rx and Tx               |
| 146        | IntDefaul tHandler, | // UART5 Rx and Tx               |
| 147        | IntDefaul tHandler, | // UART6 Rx and Tx               |
| 148        | IntDefaul tHandler, | // UART7 Rx and Tx               |
| 149        | 0,                  | // Reserved                      |
| 150        | 0,                  | // Reserved                      |
| 151        | 0,                  | // Reserved                      |
|            |                     |                                  |
| 152        | 0,                  | // Reserved                      |
| 153        | IntDefaul tHandler, | // I2C2 Master and Slave         |
| 154        | IntDefaul tHandler, | // I2C3 Master and Slave         |
| 155        | IntDefaul tHandler, | // Timer 4 subtimer A            |
| 156        | IntDefaul tHandler, | // Timer 4 subtimer B            |
| 157        | 0,                  | // Reserved                      |
|            |                     |                                  |
| 158<br>150 | 0,                  | // Reserved                      |
| 159        | 0,                  | // Reserved                      |
| 160        | 0,                  | // Reserved                      |
| 161        | 0,                  | // Reserved                      |
| 162        | 0,                  | // Reserved                      |
| 163        | 0,                  | // Reserved                      |
| 164        | 0,                  | // Reserved                      |
|            | _                   |                                  |
| 165        | 0,                  | // Reserved                      |
| 166        | 0,                  | // Reserved                      |
| 167        | 0,                  | // Reserved                      |
| 168        | 0,                  | // Reserved                      |
|            |                     |                                  |

| 169    | 0,                  | // Reserved                    |
|--------|---------------------|--------------------------------|
| 170    | 0,                  | // Reserved                    |
| 171    | 0,                  | // Reserved                    |
| 172    | 0,                  | // Reserved                    |
| 173    | 0,                  | // Reserved                    |
| 174    | 0,                  | // Reserved                    |
| 175    | 0,                  | // Reserved                    |
| 176    |                     | // Reserved                    |
|        | 0,                  | // Timer 5 subtimer A          |
| 177    | IntDefaultHandler,  |                                |
| 178    | IntDefaultHandler,  | // Timer 5 subtimer B          |
| 179    | IntDefaul tHandler, | // Wide Timer O subtimer A     |
| 180    | IntDefaul tHandler, | // Wide Timer O subtimer B     |
| 181    | IntDefaul tHandler, | // Wide Timer 1 subtimer A     |
| 182    | IntDefaul tHandler, | // Wide Timer 1 subtimer B     |
| 183    | IntDefaul tHandler, | // Wide Timer 2 subtimer A     |
| 184    | IntDefaul tHandler, | // Wide Timer 2 subtimer B     |
| 185    | IntDefaul tHandler, | // Wide Timer 3 subtimer A     |
| 186    | IntDefaul tHandler, | // Wide Timer 3 subtimer B     |
| 187    | IntDefaul tHandler, | // Wide Timer 4 subtimer A     |
| 188    | IntDefaul tHandler, | // Wide Timer 4 Subtimer B     |
|        | •                   | // Wide Timer 4 Subtimer B     |
| 189    | WideTimer5Isr,      |                                |
| 190    | IntDefaultHandler,  | // Wide Timer 5 subtimer B     |
| 191    | IntDefaul tHandler, | // FPU                         |
| 192    | 0,                  | // Reserved                    |
| 193    | 0,                  | // Reserved                    |
| 194    | IntDefaul tHandler, | // I2C4 Master and Slave       |
| 195    | IntDefaul tHandler, | // I2C5 Master and Slave       |
| 196    | IntDefaul tHandler, | // GPIO Port M                 |
| 197    | IntDefaul tHandler, | // GPIO Port N                 |
| 198    | IntDefaul tHandler, | // Quadrature Encoder 2        |
| 199    | 0,                  | // Reserved                    |
| 200    | 0,                  | // Reserved                    |
| 200    | IntDefaul tHandler, | // GPIO Port P (Summary or PO) |
| 201    |                     |                                |
|        | IntDefaultHandler,  | // GPIO Port P1                |
| 203    | IntDefaultHandler,  | // GPIO Port P2                |
| 204    | IntDefaul tHandler, | // GPIO Port P3                |
| 205    | IntDefaul tHandler, | // GPIO Port P4                |
| 206    | IntDefaul tHandler, | // GPIO Port P5                |
| 207    | IntDefaul tHandler, | // GPIO Port P6                |
| 208    | IntDefaul tHandler, | // GPIO Port P7                |
| 209    | IntDefaul tHandler, | // GPIO Port Q (Summary or QO) |
| 210    |                     | // GPIO Port Q1                |
| 211    |                     | // GPIO Port Q2                |
| 212    | IntDefaul tHandler, | // GPI 0 Port Q3               |
| 213    |                     | // GPIO Port Q4                |
|        |                     |                                |
| 214    |                     | // GPIO Port Q5                |
| 215    |                     | // GPIO Port Q6                |
| 216    |                     | // GPI 0 Port Q7               |
| 217    | IntDefaul tHandler, | // GPIO Port R                 |
| 218    | IntDefaul tHandler, | // GPIO Port S                 |
| 219    | IntDefaul tHandler, | // PWM 1 Generator 0           |
| 220    | IntDefaul tHandler, | // PWM 1 Generator 1           |
| 221    | IntDefaul tHandler, | // PWM 1 Generator 2           |
| 222    |                     | // PWM 1 Generator 3           |
| 223    | IntDefaul tHandler  | // PWM 1 Fault                 |
| 224 }; |                     |                                |
| · J /  |                     |                                |

```
225
227 //
228 // This is the code that gets called when the processor first starts execution
229 // following a reset event. Only the absolutely necessary set is performed,
230 // after which the application supplied entry() routine is called. Any fancy
231// actions (such as making decisions based on the reset cause register, and
232// resetting the bits in that register) are left solely in the hands of the
233 // application.
234//
236 voi d
237 Reset I SR (voi d)
238 {
239
     // Jump to the CCS C initialization routine. This will enable the
240
     // floating-point unit as well, so that does not need to be done here.
241
242
     __asm(" .global _c_int00\n" b.w _c_int00");
243
244
             b. w _c_i nt00");
245}
246
249 // This is the code that gets called when the processor receives a NMI. This
250 // simply enters an infinite loop, preserving the system state for examination
251// by a debugger.
252 //
253//**************************
254 static void
255 Nmi SR(voi d)
256 {
257
258
     // Enter an infinite loop.
259
     //
260
     while (1)
261
     {
262
     }
263}
264
267// This is the code that gets called when the processor receives a fault
268// interrupt. This simply enters an infinite loop, preserving the system state
269// for examination by a debugger.
270 //
272 static void
273 Faul t I SR (voi d)
274 {
275
     //
276
     // Enter an infinite loop.
277
278
     while (1)
279
280
     }
```

```
281 }
282
284//
285// This is the code that gets called when the processor receives an unexpected
286// interrupt. This simply enters an infinite loop, preserving the system state
287// for examination by a debugger.
288//
290 static void
291 IntDefaul tHandler(void)
292 {
293
294
    // Go into an infinite loop.
295
    //
296
    while(1)
297
298
     }
299 }
300
```